/*
 * @Author: ws
 * @Date: 2024-01-05 10:55:15
 * @email: 458658538@qq.com
 * @LastEditors: ws
 * @LastEditTime: 2024-01-05 11:55:49
 * @Description:
 */
/**
 * 全局组件自动注册
 *
 * 全局组件各个组件按文件夹区分，文件夹名称与组件名无关联，但建议与组件名保持一致
 * 文件夹内至少保留一个文件名为 index 的组件入口，例如 index.vue
 * 普通组件必须设置 name 并保证其唯一，自动注册会将组件的 name 设为组件名，可参考 SvgIcon 组件写法
 */

import Vue from "vue";

const componentsContext = require.context("./", true, /index.(vue|js)$/);
componentsContext.keys().forEach((file_name) => {
  // 获取文件中的 default 模块
  const componentConfig = componentsContext(file_name).default;
  if (/.vue$/.test(file_name)) {
    Vue.component(componentConfig.name, componentConfig);
  } else {
    Vue.use(componentConfig);
  }
});

const wToolContext = require.context("./WTool", true, /\.vue$/);
wToolContext.keys().forEach((file_name) => {
  // console.log(file_name);
  // debugger;
  // 获取文件中的 default 模块
  const componentConfig = wToolContext(file_name).default;
  if (/.vue$/.test(file_name)) {
    Vue.component(componentConfig.name, componentConfig);
  } else {
    Vue.use(componentConfig);
  }
});
